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A METHOD FOR DETERMINING A HUE ADJUSTMENT TO AN 

INPUT HUE 

RELATED APPLICATIONS 
Cross reference is made to the following applications filed concurrently 
herewith: Attorney Docket Number D/A2068Q entitled "A METHOD FOR 
SQUEEZING AN INPUT HUE TOWARD A REGION OF PREFERRED HUE" by 
Karen M. Braun; and Attorney Docket Number D/A2068Q1 entitled "A METHOD 
5 FOR DETERMINING AN ADJUSTMENT AMOUNT TO AN INPUT CHROMA" by 
Karen M. Braun. 

FIELD OF THE INVENTION 
The present invention generally relates to methods for converting color 
values and, more particularly, to methods for adjusting input colors in the 
direction of a specified output color to improve image appearance. 

BACKGROUND OF THE INVENTION 

10 Film companies are known to change certain colors to, for instance, show 

skin more tanned or the sky a different shade of blue. This is relatively easy 
when one has control over most every aspect of the image capturing and image 
production process. However, when the input image has been captured and 
rendered in an unknown way, improving certain colors therein becomes more 

15 complicated. This often involves segmenting colors believed to make up a 
certain color then adjusting these toward a preferred color point. This is 
computationally intensive, subject to failure, and often results in non-smooth 
transitions between different color regions such as skin color and non-skin color 
areas. 

20 Another approach is to specify both original and desired color and then 

apply a vector from original to desired color with the effect of the vector smoothly 
decaying for nearby colors in color space. One problem with this approach is 
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non-monotonic behavior leading to color reversals. Other techniques involve a 
weighting function for transforming a color to a new color and smoothly adjusting 
surrounding colors without inducing any tone reversals using a Gaussian weight 
on the difference between the input and the desired output. This method also 
5 uses a conditional function to insure monotonicity of the input to output 
relationship. Another technique transforms an input color to a desired output 
color and colors surrounding the input color are appropriately warped to give 
smooth and monotonic output using a concept of color gravity wells toward which 
other colors are adjusted. However, this technique is specific to neutrals and 
10 pure primaries and secondaries. 

What is needed in this art is a method for adjusting input colors in the 
direction of a specified output color to improve image appearance that acts on 
colors in color space rather than adjusting the colors of certain pixels spatially to 
robustly render critical colors which are known a priori. 

BRIEF SUMMARY 

15 A method is disclosed for determining a hue adjustment to an input hue, 

Hin, to squeeze the input hue toward a region of preferred hue, H pre f. The 
method involving defining a change in hue as: AH = H jn - H pre f; defining a hue 
weight as a Gaussian function: H we ight = Gaussian(H P ref,H S igma) wherein the 
Gaussian function can be alternatively replaced by one of either the sum of two 

20 Gaussians or a Gaussian convolved with a Rect function; defining an amount of 
hue adjustment as: HAdjust = AH * H we jght- Then, an output hue is generated by 
applying the adjustment such that: H ou t = H in - H A djust- 

The present invention offers a plurality of advantages. For example, the 
input can also be squeezed toward a point in either RGB, a*b*, or uV space. 

25 Multiple hue centers can be use to sequentially squeeze the input toward a 
region of a preferred skin, sky, or grass. In the case of multiple squeezes, finite 
non-overlapping regions of support maintain the shifts from previous squeezes. 
The inputs can be pre-specified in a color management system or specified and 
provided dynamically. When squeezing is applied in a non-uniform way, a left 
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side of a weighting curve and a right side of another are used to find regions of 
rapid decrease in quality for positive AH* a b renditions of certain tones. 

DESCRIPTION OF THE SPECIFICATION 
One method is disclosed for determining a hue adjustment to an input 
hue, H in , to squeeze the input hue toward a region of preferred hue, H pre f. The 
5 method involves obtaining a change in hue as: AH = Hj n - H pre f and a hue weight 
as: H W eight = Gaussian(H P ref,H S igma). An amount of hue adjustment is calculated 
by: H A djust = AH * H we j g ht. Then, an output hue is generated by applying the 
adjustment such that: H ou t = H in - H Acf j USt . 

Change in hue, AH, is the difference between the input hue, H jn is the hue 
10 of a given pixel in the image (or node in the table) and the preferred hue, H pre f. 

AH = Hjn " Hpref 

Hweight = GaUSSian(H Dre f,H S igma) 
HAdjust = AH * H W eight 
H 0 ut = Hj n - HAdjust 

15 The weight approaches 1 at the peak of the Gaussian. When H in is close 

to the preferred hue, H pre f, the AH causes the hue adjustment (H A djust) to be small 
so the output hue is very similar to the input hue (not rotated completely to the 
preferred hue). Hues very close to, or very far from, the preferred hue, get the 
least amount of shift. 

20 Also disclosed is a method for squeezing an input hue, H in , toward a 

region of preferred hue, H pre f, having a preferred chroma, C pre f, and luminance, 
Lpret, to restrict the rotation effect to a point in LCH space rather than an entire 
hue slice. This method involves first defining a chroma weight as: C we ight = 
Gaussian(Cpref,C S igma); then, defining a luminance weight as: L we ight = 

25 Gaussian(L pr ef J L sl g ma ); defining a hue weight as: H we i g ht = Gaussian(H pre f,H S igma); 
defining an amount of hue adjustment as: H A djust = AH* (H we jght*C weight* Ueight); 
then, generating an output hue by applying hue adjustment to input hue such 

that: H 0 ut = Hj n - HAdjust- 



3 



To restrict the rotation effect to be toward a point in LCH space, rather 
than toward an entire hue slice: 

^weight = Gaussian(C P ref,C S igma) 

■-weight = GaUSSian (L p ref,L S igma) 

5 H W eight = Gaussian(H P ref,H S jg ma ) 

HAdjust = AH * (H weight * Cweight * Lweight) 
Hout = Hj n p U t " HAdjust 

Alternately, the weighting function was altered to be a Gaussian was 
convolved with a Rect function, which allows independent control over how much 
10 to adjust colors and how far away from H pre f to change the colors. 

Preferably, the weighting function is replaced by the addition of two 
Gaussians, which allows additional flexibility over how colors are moved toward 
the preferred point by allowing additional parameters (K, M) for the adjustment. 

-(//_ in-M ) 2 -(//_ in+M ) 2 



weightjmp = e 2 * H - si s™ 2 + e 2 *"--*™ 2 

15 Hweight = K * weighMmp / max(weighMmp) 

The constant K in the second equation is adjusted such that no crossovers occur 
in hue. This parameter is adjusted such that the relationship between H ou t and 
H in is monotonically increasing. 

Also disclosed is a method for determining an adjustment amount to be 

20 made to an input chroma, C in , to squeeze the input chroma toward a region of 
preferred chroma, C pre f. This method involving first defining a change in chroma 
as: AC = C in - C P ref and defining a chroma weight as: C we ight = 
Gaussian(Cpref,C S igma). Then, an amount of chroma adjustment is then: CAdjust = 
AC * (H we ight*Cweight*Lweight). An output chroma is generated by applying chroma 

25 adjustment to chroma input: 

Cout = Cj n - CAdjust- 
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The change in chroma, AC, is the difference between the chroma of 
interest, Cj n and the preferred chroma, C pre f. 

AC = Cj n - Cpref 



Cweight 


= GaUSSian (Cpref, Csigma) 


Lweight 


= GaUSSian (L pr ef,L S igma) 


Hweight 


= GaUSSian (Hpref,H sj gma) 


C Adjust 


= AC * (H we jght*C W eight*Lweight) 


Cout 


= Cjn" CAdjust 



Although the current description is directed toward three one-dimensional 
10 Gaussian functions to C* and h°, it is intended to also be directed toward a single 
three-dimensional Gaussian. 

The present method is also extensible to squeezing colors toward a point 
in RGB space, a*b* (as opposed to h°/C*) space, uV space, etc. 

Because of the sequential nature of the present method, colors are 
15 squeezed toward a point and not shifted directly to that point. Colors near the 
preferred point don't change much as the hue adjustment approaches 0, and this 
prevents hues from crossing the preferred point or hue reversals. 

The present invention is additionally applicable for multiple hue centers, 
for example, to squeeze toward preferred skin, sky, and grass. This is done 
20 sequentially, but as each subsequent squeeze occurs, the former preferred 
points also be inadvertently shifted. Therefore, in the case of multiple squeezes, 
finite non-overlapping regions of support are defined making certain to produce 
smooth transitions between these regions. The squeezing is alternately applied 
in a non-uniform way, for example, to account for a rapid decrease in quality for 
25 positive AH*ab (yellow) renditions of skin tones. This only involves using the left 
side of one weighting curve and the right side of another; this is accomplished 
using two different values of H S j g ma- 

The present method can be applied in a device or in an abstract profile. 
The preferred colors can be pre-specified in the color management system or 
30 dynamically specified by the user. 
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Further advantages include no need for segmentation or other knowledge 
of input image; no need to specify original color or color vector; monotonicity (no 
crossovers), smoothness, and flexibility (e.g., the size of the region of 
surrounding colors this is affected by the "squeezing" can be varied). 

5 While particular embodiments have been described, alternatives, 

modifications, variations, improvements, and substantial equivalents that are or 
may be presently unforeseen may arise to applicants or others skilled in the art. 
Accordingly, the appended claims as filed and as they may be amended are 
intended to embrace all such alternatives, modifications variations, 

10 improvements, and substantial equivalents. 



